Security News
UK Officials Consider Banning Ransomware Payments from Public Entities
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.
decode-ico
Advanced tools
Decode .ico
icons
npm install --save decode-ico
const decodeIco = require('decode-ico')
const fs = require('fs')
const source = fs.readFileSync('favicon.ico')
const images = decodeIco(source)
console.log(images[0])
//=> { width: 16, height: 16, type: 'bmp', data: Uint8Array(...), bpp: 32, hotspot: null }
console.log(images[1])
//=> { width: 32, height: 32, type: 'bmp', data: Uint8Array(...), bpp: 32, hotspot: null }
decodeIco(source: ArrayBuffer | Buffer) => Image[]
Decodes the .ico
file in the given buffer, and returns an array of images.
Each image has the following properties:
width: Number
- The width of the image, in pixelsheight: Number
- The height of the image, in pixelstype: String
- The type of image, will be one of bmp
or png
bpp: Number
- The color depth of the image as the number of bits used per pixeldata: Uint8Array
- The data of the image, format depends on type
, see belowhotspot: null | Hotspot
- If the image is a cursor (.cur
), this is the hotspotThe format of the data
parameter depends on the type of image. When the image is of type bmp
, the data
array will hold raw pixel data in the RGBA order, with integer values between 0 and 255 (included). When the type is png
, the array will be png data.
The hotspot
property will either be null
, or an object with an x
and y
property.
💡 The png
data can be written to a file with the .png
extension directly, or be decoded by node-lodepng which will give you the same raw format as the bmp
type.
FAQs
Decode `.ico` icons
The npm package decode-ico receives a total of 52,630 weekly downloads. As such, decode-ico popularity was classified as popular.
We found that decode-ico demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.
Security News
Snyk's use of malicious npm packages for research raises ethical concerns, highlighting risks in public deployment, data exfiltration, and unauthorized testing.
Research
Security News
Socket researchers found several malicious npm packages typosquatting Chalk and Chokidar, targeting Node.js developers with kill switches and data theft.